home *** CD-ROM | disk | FTP | other *** search
/ Aminet 2 / Aminet AMIGA CDROM (1994)(Walnut Creek)[Feb 1994][W.O. 44790-1].iso / Aminet / util / gnu / GNU_OLEO_1_2_2.lha / oleo-1.2.2 / global.h < prev    next >
C/C++ Source or Header  |  1993-03-03  |  6KB  |  222 lines

  1. #ifndef GLOBALH
  2. #define GLOBALH
  3.  
  4. /*    Copyright (C) 1990, 1992, 1993 Free Software Foundation, Inc.
  5.  
  6. This program is free software; you can redistribute it and/or modify
  7. it under the terms of the GNU General Public License as published by
  8. the Free Software Foundation; either version 2, or (at your option)
  9. any later version.
  10.  
  11. This program is distributed in the hope that it will be useful,
  12. but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  14. GNU General Public License for more details.
  15.  
  16. You should have received a copy of the GNU General Public License
  17. along with this software; see the file COPYING.  If not, write to
  18. the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.  */
  19.  
  20. #include "sysdef.h"
  21. #include "utils.h"
  22.  
  23.  
  24. #define RCFILE ".oleorc"
  25.  
  26. /* The most important compile-time constant.  How many bits do we want to
  27.    allocate for cell-references?  Useful values are 8 and 16 (at the moment)
  28.    8 allows luser to access 255*255 cells (probably big enough)
  29.    16 allows luser to access 65535*65535, which is more than will fit in
  30.    the avaliable virtual memory on any 32-bit machine.
  31.  */
  32.  
  33. #ifndef BITS_PER_CELLREF
  34. #define BITS_PER_CELLREF 8
  35. #endif
  36.  
  37. /* The location of a cell that can never be referenced */
  38. #define NON_ROW        0
  39. #define NON_COL        0
  40.  
  41. #define MIN_ROW        1
  42. #define MIN_COL     1
  43.  
  44. #if BITS_PER_CELLREF==16
  45. typedef unsigned short CELLREF;
  46. #define CELLREF_MASK 0xFFFF
  47. #define MAX_ROW 65535
  48. #define MAX_COL 65535
  49.  
  50. /* Do *not* assume that 'name' is aligned!  It probably isn't */
  51. #define GET_ROW(name)        ((((name)[0])<<8)|(name)[1])
  52. #define GET_COL(name)        ((((name)[2])<<8)|(name)[3])
  53. #define PUT_ROW(name,val)    ((name)[0]=((val)>>8)),((name)[1]=val)
  54. #define PUT_COL(name,val)    ((name)[2]=((val)>>8)),((name)[3]=val)
  55. #define EXP_ADD            sizeof(CELLREF)*2
  56. #else
  57. #if BITS_PER_CELLREF==8
  58. typedef unsigned char CELLREF;
  59. #define CELLREF_MASK 0xFF
  60. #define MAX_ROW          255
  61. #define MAX_COL       255
  62.  
  63. #define GET_ROW(name)        ((name)[0])
  64. #define GET_COL(name)        ((name)[1])
  65. #define PUT_ROW(name,val)    ((name)[0]=(val))
  66. #define PUT_COL(name,val)    ((name)[1]=(val))
  67. #define EXP_ADD            sizeof(CELLREF)*2
  68. #else
  69. FOO FOO FOO You need to define the obvious macros above
  70. #endif
  71. #endif
  72.  
  73. /* Struct rng is used to describe a region of cells */
  74. struct rng
  75. {
  76.   CELLREF lr, lc, hr, hc;
  77. };
  78.  
  79. /* A ref_fm structure contains a list of all cells that reference some
  80.  * value.  The value can be another cell or some global (such as the system
  81.  * time).
  82.  *
  83.  * These structures are hash-consed and shared.  The hash-cons procedure
  84.  * will re-use a particular structure if there is only one reference to it.
  85.  */
  86. struct ref_fm
  87. {
  88.   struct ref_fm *refs_next;
  89.   unsigned short refs_refcnt;
  90.   unsigned short refs_used;
  91.   struct ref_array
  92.     {
  93.       CELLREF ref_row;
  94.       CELLREF ref_col;
  95.     } fm_refs[1];
  96. };
  97.  
  98. /* refs_to is a vector of locations in a formula where the
  99.  * cell references other cells, ranges, or variables 
  100.  */
  101. struct ref_to
  102. {
  103.   unsigned short refs_refcnt;
  104.   struct ref_to *refs_next;
  105.   unsigned short refs_used;
  106.   unsigned char to_refs[1];
  107. };
  108.  
  109. /* These macros are used to extract/store ranges in compiled formulas. */
  110. #define GET_RNG(name,putit)    bcopy((VOIDSTAR)(name),(VOIDSTAR)(putit),sizeof(struct rng))
  111. #define PUT_RNG(name,putit)    bcopy((VOIDSTAR)(putit),(VOIDSTAR)(name),sizeof(struct rng))
  112. #define EXP_ADD_RNG        sizeof(struct rng)
  113.  
  114. extern struct obstack tmp_mem;
  115. extern VOIDSTAR tmp_mem_start;
  116.  
  117. #define ERR_MAX        17
  118. extern char *ename[];
  119. extern char tname[];
  120. extern char fname[];
  121. extern char iname[];
  122. extern char mname[];
  123. extern char nname[];
  124.  
  125. extern VOIDSTAR parse_hash;
  126. extern double __plinf, __neinf, __nan;
  127.  
  128. extern CELLREF curow, cucol;
  129. extern CELLREF cur_row, cur_col;
  130.  
  131. extern int default_jst;
  132. extern int default_fmt;
  133. extern int default_lock;
  134.  
  135. extern unsigned short current_cycle;
  136. extern int a0;
  137. extern int errno;
  138. extern const char oleo_version_string[];
  139.  
  140. #ifdef __STDC__
  141.  
  142. extern double astof (char **);
  143. extern long astol (char **);
  144. extern void free (void *);
  145. extern void panic (const char *, ...);
  146.  
  147. extern VOIDSTAR init_stack (void);
  148. extern void flush_stack (void *);
  149. extern void push_stack (void *, void *);
  150. extern VOIDSTAR pop_stack (void *);
  151. extern int size_stack (void *);
  152.  
  153. extern void add_ref (CELLREF, CELLREF);
  154. extern void add_range_ref (struct rng *);
  155. extern void add_timer_ref (int);
  156. extern void add_ref_to (int);
  157.  
  158. struct hash_control; /* in case it hasn't been declared yet */
  159. extern char *hash_insert (struct hash_control *, char *, VOIDSTAR);
  160.  
  161. extern char *jst_to_str (int);
  162. extern char *fmt_to_str (int);
  163.  
  164. #ifdef A0_REFS
  165. extern char *col_to_str (CELLREF);
  166. #endif
  167.  
  168. extern char *flt_to_str (double);
  169. extern void push_refs (struct ref_fm *);
  170. extern void no_more_cells (void);
  171.  
  172. extern char *range_name (struct rng *);
  173. extern char *cell_name (CELLREF, CELLREF);
  174.  
  175. extern char *new_value (CELLREF, CELLREF, char *);
  176.  
  177. extern unsigned char parse_cell_or_range (char **, struct rng *);
  178.  
  179. struct var; /* in case it hasn't been declared yet */
  180. extern void for_all_vars (void (*)(char *, struct var *));
  181. #else
  182.  
  183. extern double astof ();
  184. extern long astol ();
  185. extern void free ();
  186. extern void panic ();
  187.  
  188. extern VOIDSTAR init_stack ();
  189. extern void flush_stack ();
  190. extern void push_stack ();
  191. extern VOIDSTAR pop_stack ();
  192. extern int size_stack ();
  193.  
  194. extern void add_ref ();
  195. extern void add_range_ref ();
  196. extern void add_timer_ref ();
  197. extern void add_ref_to ();
  198.  
  199. extern char *hash_insert ();
  200. extern char *jst_to_str ();
  201. extern char *fmt_to_str ();
  202.  
  203. #ifdef A0_REFS
  204. extern char *col_to_str ();
  205. #endif
  206.  
  207. extern char *flt_to_str ();
  208. extern void push_refs ();
  209. extern void no_more_cells ();
  210.  
  211. extern char *range_name ();
  212. extern char *cell_name ();
  213.  
  214. extern char *new_value ();
  215.  
  216. extern unsigned char parse_cell_or_range ();
  217.  
  218. extern void for_all_vars ();
  219. #endif
  220.  
  221. #endif
  222.